 package pl.exsio.querydsl.entityql.examples.jpa.entity.generated

 import com.querydsl.core.types.Path
 import com.querydsl.sql.PrimaryKey
 import pl.exsio.querydsl.entityql.QColumnMetadataFactory
 import pl.exsio.querydsl.entityql.QPathConfig
 import pl.exsio.querydsl.entityql.QPathFactory
 import pl.exsio.querydsl.entityql.QStaticModel
 import com.querydsl.sql.ForeignKey
 import pl.exsio.querydsl.entityql.examples.jpa.entity.Order
 import com.querydsl.core.types.dsl.NumberPath
 import pl.exsio.querydsl.entityql.examples.jpa.entity.User
 import pl.exsio.querydsl.entityql.examples.jpa.entity.OrderItem
 import javax.annotation.Generated
 import java.util.Arrays
 import groovy.transform.CompileStatic
 
 /**
 *
 * This class was generated by EntityQL (https://github.com/eXsio/querydsl-entityql).
 * It is not recommended to make any changes to this class.
 * Any manual changes will be lost upon the next class generation.
 *
 */
 @CompileStatic
 @Generated("pl.exsio.querydsl.entityql.QExporter")
 public final class QOrder extends QStaticModel<Order> {

     private static final long serialVersionUID = 1021087534

     public static final QOrder INSTANCE = new QOrder()

     public static final QOrder qOrder = INSTANCE

     public final NumberPath<Long> id

     public final NumberPath<Long> userId

     public final ForeignKey<User> user

     public final ForeignKey<OrderItem> items

     public final ForeignKey<OrderItem> itemsReferenced

     public final PrimaryKey<Order> _primaryKey

     public QOrder() {
         this("ORDERS")
     }
     @SuppressWarnings(value = "unchecked")
     public QOrder(String variable) {
         super(Order.class, variable, "", "ORDERS")
         id: {
             QPathConfig config = new QPathConfig(Long.class, Long.class, "ORDER_ID", true, 1, -5)
             this.id = QPathFactory.<NumberPath<Long>>create(this, config)
             addMetadata(this.id, QColumnMetadataFactory.create(config))
             this.columnsMap.put("id", this.id)
         }

         userId: {
             QPathConfig config = new QPathConfig(Long.class, Long.class, "USER_ID", false, 2, -5)
             this.userId = QPathFactory.<NumberPath<Long>>create(this, config)
             addMetadata(this.userId, QColumnMetadataFactory.create(config))
             this.columnsMap.put("userId", this.userId)
         }

         user: {
             this.user = this.<User>createForeignKey(this.userId, "USER_ID")
             this.joinColumnsMap.put("user", this.user)
         }

         items: {
             QPathConfig config0 = new QPathConfig(Long.class, Long.class, "ORDER_ID", false, 3, -5)
             Path<?> items0 = QPathFactory.<Path>create(this, config0)
             addMetadata(items0, QColumnMetadataFactory.create(config0))
             this.items = this.<OrderItem>createInvForeignKey(Arrays.<Path<?>>asList(items0), Arrays.asList("ITEM_ORDER_ID"))
             this.inverseJoinColumnsMap.put("items", this.items)
         }

         itemsReferenced: {
             QPathConfig config0 = new QPathConfig(Long.class, Long.class, "ORDER_ID", false, 4, -5)
             Path<?> itemsReferenced0 = QPathFactory.<Path>create(this, config0)
             addMetadata(itemsReferenced0, QColumnMetadataFactory.create(config0))
             this.itemsReferenced = this.<OrderItem>createInvForeignKey(Arrays.<Path<?>>asList(itemsReferenced0), Arrays.asList("ITEM_ORDER_ID"))
             this.inverseJoinColumnsMap.put("itemsReferenced", this.itemsReferenced)
         }

         _primaryKey: {
             this.primaryKeyColumns = Arrays.<Path<?>>asList(this.id)
             Path[] pkArray = (Path[]) primaryKeyColumns.<Path>toArray(new Path[0])
             this._primaryKey = this.<Order>createPrimaryKey(pkArray)
         }

     }
 } 